Azure Single Sign-On for Web Client

Single Sign-On (SSO) adds more security and convenience when signing on to Nectari using Azure Active Directory (Azure AD).

This topic describes how to set up Azure with Nectari.

Configuring the Azure Domain

You must first configure the Azure Domain, as this is the platform from which we retrieve the data required to correctly set up Nectari.

  1. In your Web browser, go to https://portal.azure.com/ and enter your login credentials (if required).
  2. In the left menu, click Enterprise Applications.

  3. In the upper bar, click + New application.

  4. Under the Add your own app section, select Non-gallery application.

  5. In the Name field, enter a name for your application and click Add.

  6. Under the Getting Started section, select 2. Set up single sign on.

  7. Select SAML for the single sign-on method.

Although there are 5 sections for the SAML SSO method, you only need to set the parameters in these sections:

Basic SAML Configuration

  1. In the upper-right corner, click the pencil to edit the parameters in the Basic SAML Configuration section.

  2. In the Identifier (Entity ID) field, enter your Nectari URL + :port followed by a Unique Identifier for your Azure Domain. The URL and the port should be the same as those entered during the Nectari installation.

    Important

    Only for users who never performed the https binding for external access: Take note of URL address used for the Web Client on your certificate to communicate with the Azure Domain. This is explained in further detail in Configuring the Nectari Server.

    Example

    In this example we have biwebserver.mycompany.com as the URL address with port :444 and biwebclient as Unique Identifier for the Azure Domain.

  3. In the Reply URL (Assertion Consumer Service URL) field, enter your Nectari URL + :port followed by /AuthServices/Acs.

  4. Click Save to apply changes.

  5. In the left menu, under the Manage section, click Users and groups.

  6. In the upper bar, click + Add user to authorize users and groups to use SSO.

    This completes the basic SAML configuration.

User Attributes & Claims

In the Azure Domain, you can take the attributes listed in the User Attributes & Claims section.

If you want to use the mailnickname attribute (because you want to choose the part of the email address before the @ sign), you will have to create it, since this attribute does not exist by default in Azure Domain.

To create the attribute:

  1. In the left menu, under the Manage section, click Single Sign-On.

  2. In the upper-right corner, click the pencil to edit the User Attributes & Claims section.

  3. Click + Add new claim.
  4. In the Name field, enter mailnickname.
  5. For the Source, select Attribute.
  6. In the Source Attribute field, enter user.mailnickname.
  7. Click Save to finish.

Configuring the Nectari Server

Before starting the Nectari Server Configuration, you must retrieve the certificate from Azure Domain.

To retrieve the certificate:

  1. Scroll to the SAML Signing Certificate section.

  2. Click Download next to the Certificate (Base64) field.

Binding the Web Client

By adding an HTTPS binding to your Web Client, external connections will also be secured.

To bind the Web Client:

  1. Press the Windows key + R to open the Run window.
  2. Enter inetmgr and press the Enter key.
  3. On the left pane, click the little arrow to expand the connection tree structure.
  4. In the Sites tab, right-click on WebClient and select Edit Bindings...
  5. In the Site Bindings window, click Add...
  6. In the Type drop-down list, select https. For this HTTPS connection, we are using port number 444 but you can customize it according to your preferences.

  1. Click OK to finish.

    You should have a result similar to this:

Editing the web.config file

In order to fully benefit from Azure SSO functionality, you will have to edit the web.config file located in C:\inetpub\wwwroot\WebClient.

  • Make sure the entityID attribute from the sustainsys.saml2 tag has the same value you defined in the Identifier (Entity ID) field in the basic SAML configuration. In our example we set "https://biwebserver.mycompany.com:444/biwebclient" as value.
  • Change the other values in the Nectari web.config file as described in the table below:
Attribute to be changed in the web.config file Value before change Value after change Comment
returnUrl "http://biwebserver.mycompany.com:444/Account/SSO" "https://biwebserver.mycompany.com:444/Account/SSO" We added an s to http since we want this connection to be secured.
entityID from the identityProviders tag "https://stubidp.sustainsys.com/Metadata" "https://sts.windows.net/c2c50f21-66a7-xxxx-xxxx-xxxxxxxxxxxx/" This is the value you retrieved from the Azure AD Identifier field in the Set up BI Web Server section
signOnUrl from the identityProviders tag "https://stubidp.sustainsys.com/" "https://login.microsoftonline.com/c2c50f21-66a7-xxxx-xxxx-xxxxxxxxxxxx/saml2" This is the value you retrieved from the Azure Login URL field in the Set up BI Web Server section
Important

Web Browsers have updated their policy regarding cookies and these changes must be applied to your Web Client if you want Nectari embedded into your ERP website, or use Single Sign-On (SSO). Refer to Cookie Management for more details.

Attribute to be changed in Nectari web.config file Value before change Value after change
cookieSameSite
<sessionState cookieSameSite="Lax"/>
<sessionState cookieSameSite="None"/>
httpOnlyCookies / requireSSL / sameSite
<httpCookies httpOnlyCookies="true" requireSSL="false" sameSite="Lax"/>
<httpCookies httpOnlyCookies="true" requireSSL="true" sameSite="None"/>

Expected result for the Web Client

<sustainsys.saml2 entityId="https://biwebserver.mycompany.com:444/biwebclient" returnUrl="https://biwebserver.mycompany.com:444/Account/SSO" modulePath="/AuthServices">
        <identityProviders>
            <add entityId="https://sts.windows.net/c2c50f21-66a7-xxxx-xxxx-xxxxxxxxxxxx/" signOnUrl="https://login.microsoftonline.com/c2c50f21-66a7-xxxx-xxxx-xxxxxxxxxxxx/saml2" allowUnsolicitedAuthnResponse="true" binding="HttpRedirect">
                <signingCertificate fileName="~/App_Data/AzureBIWebServer.cer"/>
            </add>
        </identityProviders>
</sustainsys.saml2>

Expected result for the cookies

<system.web>
        <sessionState cookieSameSite="None"/>
        <compilation targetFramework="4.8">
            <assemblies>
                <add assembly="System.Core, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089"/>
            </assemblies>
        </compilation>
        <!-- change value of MaxHttpCollectionKeys to max int(2147483644) to webserver support recsive big data-->
        <httpRuntime targetFramework="4.8" maxUrlLength="10999" maxRequestLength="2147483644" executionTimeout="1600" useFullyQualifiedRedirectUrl="false" requestLengthDiskThreshold="2147483647" maxQueryStringLength="2097151"/>
        <httpCookies httpOnlyCookies="true" requireSSL="true" sameSite="None"/>
</system.web>

Steps after the Configuration

Copying the Azure Domain Certificate

  • Copy the certificate you downloaded from Azure Domain and paste it to C:\inetpub\wwwroot\WebClient\App_Data.

Creating Users and Groups in Nectari

  • Refer to Users to create your Web Client user by entering the same value for User Name and SAML2 answer's Attribute for user name you defined during the installation of the package.
Example

Here is an example of user as we chose mailnickname for the attribute.

Accessing Nectari with Azure SSO enabled

To log in with SSO enabled, use your default Web Client URL:

https://biwebserver.mycompany.com:444

If your Admin account is not set up with SSO and you need to log in, use this URL to log in with your default credentials (without SSO):

https://biwebserver.mycompany.com:444/Account/Login